<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <a href="/home">主页</a>
    |
    <a href="/news">新闻</a>

    <div id="dv"></div>
</body>

</html>

<script>
    //history模式
    //利用H5新增的api pushState（） replaceState（）来进行封装
    //不能用file协议打开
    //核心事件：onpopstate
    //触发popstate的条件是 点击浏览器的左右箭头
    //相同路径会向服务器发起请求，把url当成请求地址，向后端发起请求，造成404的问题

    let as = document.querySelectorAll("a");

    [...as].forEach(a => {
        a.onclick = function (e) {
            //阻止默认事件
            e.preventDefault(e)
            // console.dir(a);
            let path = this.pathname; //获取当前标签的路径
            //调用H5的api，pushState
            history.pushState({
                name: "李雷"
            }, null, path)
        }
    })

    //核心事件
    window.onpopstate = function(e){
        console.log(e);
    }
</script>